// 1.导入 axios 包
import axios from 'axios'

import store from '@/store/index.js'
import router from '@/router/index.js'

import { Loading } from 'element-ui'

// 2.调用 axios.create() 函数
const request = axios.create({
  baseURL: 'http://www.liulongbin.top:3008'
})
let instance = null
// 添加请求拦截器
request.interceptors.request.use((config) => {
  // 在发送请求之前做些什么
  instance = Loading.service({
    background: 'rgba(0, 0, 0, 0.8)',
    spinner: 'el-icon-loading',
    text: '数据加载中...'
  })
  if (config.url.startsWith('/my')) {
    config.headers.Authorization = store.state.token
  }
  return config
}, (error) => {
  // 对请求错误做些什么
  instance.close()
  return Promise.reject(error)
})
// 添加响应拦截器
request.interceptors.response.use((response) => {
  // 对响应数据做点什么
  instance.close()
  return response
}, (error) => {
  // 对响应错误做点什么
  instance.close()
  if (error.response.status === 401) {
    store.commit('updateToken', '')
    router.push('/login')
  }
  return Promise.reject(error)
})
// 3.导出 axios 的实例对象
export default request
